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SYSTEM AND METHOD FOR ABSTRACTING STATE TRANSITIONS WITHOUT 
REQUIRING STATE MACHINE KNOWLEDGE 

TECHNICAL FIELD 

5 The present invention relates generally to systems and methods for abstracting 

from a client the state transitions of an object on a server. More particularly, the invention is 
directed to abstracting from various clients the states of an object in a knowledge 
management system so that the actions that the client can perform on the object are 
dynamically determined. 

10 

BACKGROUND OF THE INVENTION 

As the amount of information stored by computer systems continues its exponential 
growth, companies are developing sophisticated information organization methods to aid 
users in both the storage and retrieval of that information. The ability to capture information, 

15 knowledge, and data has created a demand on organizations to absorb and analyze this 
information, knowledge, and data in a focused way. Organizations and people within 
organizations that effectively harness this information, knowledge, and data have a 
competitive advantage. 

The onslaught of information has in turn changed the way in which people within 

20 organizations interact with information and collaborate in the preparation of projects. For 
example, the ability for people within organizations to collaborate on the preparation and 
review of a document has changed the way people interact allowing people to gain 
knowledge from their experiences and their peers' expertise. The need for effective 
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collaboration in the preparation of documents has become essential to completion of projects. 
Lack of effective collaboration affects an organization's ability to meet time-to-market 
constraints, affects bottom line costs, and minimizes top line profitability. To achieve 
effective collaboration, the collaborative environment must be optimized, information feeds 

5 must be integrated wherever possible, and the right tools must be available to visualize and 
disseminate information rapidly and meaningfully. 

Client-server environments facilitate collaboration by providing a central repository 
of information by way of a server that can provide a common platform for people to interact 
with by way of client computers. Client-server systems allow a centralized server to 

10 uniformly control aspects of the client interaction with programs and data on the server. One 
such example system is a document management system that provides a mechanism whereby 
multiple clients can collaborate in development of documents and other objects. Typically, 
such systems maintain objects in a central location (i.e. on a server) and control the access to 
the object by multiple clients. In this way, collaboration can be coordinated so that multiple 

15 clients are not simultaneously changing the object. For example, clients can access the server 
and "check-out" an object. Thereafter, other clients attempting to access the object will be 
notified that that object is in a "checked-out" state and may be prohibited from changing the 
object. Additionally, clients may see other object states such as "checked-in", "expired", and 
so on. While the server typically maintains control over the object, access to the object is 

20 typically provided by client software. Controlling the functionality of access to the object at 
the server would provide uniformity across clients and provide for a more flexible system 
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design. Hence, there is a need to provide an improved system and method for controlling the 
access to and the manipulation of objects in a client-server environment wherein a plurality 
of clients have varying access to a plurality of objects stored on the server. 

5 SUMMARY OF THE INVENTION 

To meet the above need, the present invention provides a flexible, server based 
system for controlling the operations on objects (i.e., the manner in which users can access 
and manipulate objects), particularly in a document management system. This functionality 
is achieved by providing a server-based state-transition model for objects in its domain. The 

10 state transition model maintains at the server allowable states for object and allowable 

transitions between the states. Based on that state transition model, the server can determine 
what operations are permitted to be performed on a given object to transition the object from 
its current state to a new state. Whenever a client desires to perform operations upon the 
object, the client makes a request to the server for currently permitted operations. In this 

15 way, clients are divorced from the complexity of the system (e.g., the document management 
system) and the operations that are permitted to transition a given object to a different state. 
This use of a state transition model provides among other advantages, uniformity of 
interfaces, faster system upgrades, and so on. 

The system comprises a server that maintains an object or objects to be 

20 accessed by a client. The server maintains a set of states and state transitions for each object 
and maintains a current state of each object. When the server receives a request for an object 
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from a client computer, the server provides to the client the object, the current state of the 
object, and selected state transitions. The selected state transitions are based on the current 
state. Thereafter, the client may only perform the state transitions to the object based on said 
selected state transitions provided by the server. 

5 

BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing summary, as well as the following detailed description of the preferred 
embodiments, is better understood when read in conjunction with the appended drawings. 
For the purpose of illustrating the invention, there is shown in the drawings exemplary 
10 constructions of the invention; however, the invention is not limited to the specific methods 
and instrumentalities disclosed. In the drawings: 

Figure 1 is a schematic diagram representing a network computer model in which 
aspects of the present invention may be incorporated; 

Figure 2. is an illustration of the storage and retrieval of objects and state information 
1 5 in accordance with the invention; 

Figure 3 is a flowchart illustrating the flow of control in client access to objects 
maintained by the server in accordance with the present invention; 

Figure 4 is an exemplary state diagram that illustrates the transitions of a document 
between states in accordance with an aspect of the invention; 
20 Figure 5 is an illustration of the modification of a drop-down box to include allowed 

operations on an object in accordance with an aspect of the invention; and 
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Figure 6 is an illustrative computer system on which the software and methods of the 
present invention may be executed. 
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DETAILED DESCRIPTION OF THE INVENTION 

OVERVIEW 

The present invention addresses the need for a system and method for 

5 managing collaborative access to objects. To that end, the system and method provide 
centralized control over objects and provide a platform wherein actions to be performed on 
an object are based on the current state of the object and valid transitions from those states. 
The valid states are maintained on a per-object basis and can be controlled based on the 
permissions granted to the user. 

10 EXEMPLARY OPERATING ENVIRONMENT 

The present invention is preferably deployed in a network environment, 
particularly where that network is an Internet or Intranet environment. The term "Internet" is 
an abbreviation for "Internetwork; 1 and refers commonly to the collection of networks and 
gateways that utilize the TCP/IP suite of protocols, which are well-known in the art of 

15 computer networking. TCP/IP is an acronym for "Transmission Control Protocol/Internet 
Protocol" The Internet can be described as a system of geographically distributed remote 
computer networks interconnected by computers executing networking protocols that allow 
users to interact and share information over the networks. Because of such wide-spread 
information sharing, remote networks such as the Internet have thus far generally evolved 

20 into an "open" system for which developers can design software applications for performing 
specialized operations or services, essentially without restriction. 
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Electronic information transferred between data-processing networks is usually 
presented in hypertext, a metaphor for presenting information in a manner in which text, 
images, sounds, and actions become linked together in a complex non-sequential web of 
associations that permit the user to "browse" or "navigate" through related topics, regardless 

5 of the presented order of the topics. These links are often established by both the author of a 
hypertext document and by the user, depending on the intent of the hypertext document. For 
example, traveling among links to the word "iron" in an article displayed within a graphical 
user interface in a data-processing system might lead the user to the periodic table of the 
chemical elements (i.e., linked by the word "iron"), or to a reference to the use of iron in 

10 weapons in Europe in the Dark Ages. The term "hypertext" was coined in the 1960s to 

describe documents, as presented by a computer, that express the nonlinear structure of ideas, 
as opposed to the linear format of books, film, and speech. 

The term "hypermedia," on the other hand, more recently introduced, is nearly 
synonymous with "hypertext" but focuses on the non-textual components of hypertext, such 

15 as animation, recorded sound, and video. Hypermedia is the integration of graphics, sound, 
video, or any combination thereof into a primarily associative system of information storage 
and retrieval. Hypermedia, as well as hypertext, especially in an interactive format where 
choices are controlled by the user, is structured around the idea of offering a working and 
learning environment that parallels human thinking-that is, an environment that allows the 

20 user to make associations between topics rather than move sequentially from one to the next, 
as in an alphabetic list. Hypermedia, as well, as hypertext topics, are thus linked in a manner 
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that allows the user to jump from one subject to other related subjects during a search for 
information. Hyper-link information is contained within hypermedia and hypertext 
documents, which allow a user to move back to "original" or referring network sites by the 
mere "click" (i.e., with a mouse or other pointing device) of the hyper-linked topic. 
5 A typical networked system that utilizes hypertext and hypermedia conventions 

follows a client-server architecture. The "client" is a member of a class or group that uses the 
services of another class or group to which it is not related. Thus, in computing, a client is a 
process (i.e., roughly a set of instructions or tasks) that requests a service provided by another 
program. The client process utilizes the requested service without having to "know" any 
10 working details about the other program or the service itself. In a client-server architecture, 
particularly a networked system, a client is usually a computer that accesses shared network 
resources provided by another computer (i.e., a server). 

A request by a user for, by way of example, objects such as graphics, video, text and 
so on, can be sent by a client application program to a server. A server is typically a remote 
15 computer system accessible over a remote network such as the Internet. The server scans and 
searches for raw (e.g., unprocessed) information sources (e.g., newswire feeds or 
newsgroups). Based upon such requests by the user, the server presents filtered electronic 
information as server responses to the client process. The client process may be active in a 
first computer system, and the server process may be active in a second computer system, 
20 communicating with one another over a communications medium, thus providing distributed 
functionality and allowing multiple clients to take advantage of the information-gathering 

8 
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capabilities of the server. 

Client and server communicate with one another utilizing the functionality provided 
by Hypertext-Transfer Protocol (HTTP). The World Wide Web (WWW) or, simply, the 
"Web," includes those servers adhering to this standard (i.e., HTTP) which are accessible to 
5 clients via a computer or data-processing system network address such as a Uniform 

Resource Locator (URL). The network address can be referred to as a Universal Resource 
Locator address. For example, communication can be provided over a communications 
medium. In particular, the client and server may be coupled to one another via TCP/IP 
connections for high-capacity communication. Active within the client is a first process, 
10 known as a "browser," which establishes the connection with the server and presents 
information to the user. The server itself executes corresponding server software that 
presents information to the client in the form of HTTP responses. Of course, applications 
other than browser may operate on a client and communicate with the server using HTTP. 
However, browser are one example of a common application that communicates using 
15 HTTP. The HTTP responses correspond to "web pages" constructed from a Hypertext 
Markup Language (HTML), or other server-generated data. Each web page can also be 
referred to simply as a "page." 

The client typically displays the information provided through the network by the 
server, using a software application known as a browser. Most browsers have modern 
20 graphical user interfaces that are capable of displaying and manipulating various types of 
data. A graphical user interface is a type of display format that enables a user to choose 

9 
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commands, start programs, and see lists of files and other options by pointing to pictorial 
representations (icons) and lists of menu items on the screen. Choices can be activated 
generally either with a keyboard or a mouse. Internet services are typically accessed by 
specifying a unique network address (i.e., typically with a URL). The URL address has two 
basic components, the protocol to be used and the object pathname. For example, the URL 
address, "http://www.uspto.gov" (i.e., home page for the U.S. Patent and Trademark Office), 
specifies a protocol of HTTP and a pathname of the server ("www.uspto.gov"). The server 
name is associated with one or more equivalent TCP/IP address. 

Figure 1 illustrates an exemplary environment in which the present invention may be 
employed. Of course, actual environments can be arranged in a variety of configurations; 
however, the environment is shown here in the context of a client server system to provide a 
framework for understanding the type of environment in which the present invention 
operates. The system may include client computers 20, 20a, which could be personal 
computers, thin clients, hand-held computing devices, and so on. Additionally, the system 
may include a server computer 22, and storage 70, which is coupled to and controlled by 
server computer 22. The client and server computers communicate with each other by way 
of communications network 80, which may be a LAN, a WAN, intranet, the Internet, etc. 

Client computers 20, 20a and server computer 22 are connected to 
communications network 80 by way of communications interfaces 82. Communications 
interfaces 82 can be any one of the well-known communications interfaces such as Ethernet 
connections, modem connections, DSL connections and so on. Communications interfaces 

10 
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82 may also be by way of an intermediate communications network such as a LAN. 

According to aspects of the present invention, users of client computers 20, 
20a may generate and manipulate objects 10 (e.g., DOCa) that must be stored for later 
retrieval for editing, viewing, and the like. The generic term user(s) is used herein to 

5 designate all users of the system; however, in practice user may be distinguished into 
different classes depending on his or her particular use. For example, a user may be a 
producer of documents (i.e., an author/editor/creator), a consumer (Le. a reader trying to find 
particular documents), or both. Each user may have a different set of operations that they are 
authorized to perform on document 10. As used herein, the term object refers to any file that 

10 contains data and may contain text, graphics, special codes, or a combination of some or all 
of these. To facilitate object management, the objects generated by client computers 20, 20a 
are stored in object storage 70 and are thus transmitted to server computer 22 over 
communications network 80. Server computer 22 then determines the proper storage of the 
objects in object storage 70. 

15 In addition to the generation of objects, users of client computers 20, 20a may 

also desire to share objects with other users, e.g., to collaborate on the object development. 
In order to retrieve objects generated by other users, users make requests to server computer 
22 for documents stored in object storage 70. Server computer 22 then retrieves the 
requested documents and transmits them back to the requesting user's client computer 20, 

20 20a by way of communications network 80. 

Server 22 maintains objects and information necessary to control access to the 

11 
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object in object storage 70. Figure 2 illustrates how client 20 interacts with the server 22 to 
access and manipulate an object 10. When a user of client computer 20 desires access to an 
object (e.g., DOC a ) client components 21 make a request 201a to server 22. Server 22 has a 
request infrastructure component 23 that accepts the request and retrieves (221a, 221b) the 

5 appropriate object 10 and/or object information 1 1 from object storage 70. Notably, the 
object information 1 1 comprises state information related to the potential states of the object 
(e.g., state 1, state 2, state 3, state 4), the current state of the object (e.g., shown here as cross- 
hatched state 4), and the possible state transitions (e.g., transition from state 4 to state 3). 
Some or all of this information 1 1 is transferred (201b) in connection with object 10 by 

10 server request infrastructure 23 back to client components 21 where the information can be 
conveyed to give a user appropriate allowed actions on object 10. 

According to an aspect of the invention, the operations that a given client 20, 
20a may perform on object 10 are dictated by the information 1 1 associated with object 10, 
in conjunction with the client's security permissions. Thus, for example, in the illustrative 

15 example of Figure 2 wherein the object 10 is in state 4, the object may only transition to state 
3 as indicated by the state transition to state 3 from state 4 and the lack of any other 
transitions out of state 4. Furthermore, this transition to state 3 may only be allowed for a 
certain set of clients. By maintaining the information 1 1 by server 22, any modifications to 
the information 11, such as the state model associated with object 10, can be made by way of 

20 server 22 and dynamically delivered to client 20. In this way, the system is more flexible in 

that changes made in a central location (e.g. object store 70) are replicated to a plurality of 

12 
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clients. Moreover, client 20 does not need to understand in advance all of the allowed states 
and state transitions for a given object 10 (which may differ for different objects and 
different users) but rather obtains the information as needed for each object. 

Figure 3 is a flow chart that provides further detail of the process performed by client 

5 components 21 in conjunction with server request infrastructure 23 whereby client 20 
accesses an object 10 and its related information (refer also to Figure 2), Initially, a user 
makes a request for an object by way of a client computer 20. That request is processed by 
client component 21 (301). An exemplary format for carrying out the request would be, in 
the case of a request for DOC A , for client 20 to send a command to server 22 of the format 

10 INVOKE DOC A <operation>GetOpsAllowed</operation>, This request is received by 

server request infrastructure 23 (303). In response, server request infrastructure 23 retrieves 
DOCa from object storage 70 to determine the current state (305). The server request 
additionally retrieves the current set of state transitions for the object (307). For example, 
Figure 4 illustrates an exemplary state transition diagram for a document management 

15 system. Using the example of state transitions of Figure 4, the set of valid state transitions 
could be stored in a table of the form: 



From State 


To State 


Operation (Transition) Name 


Credential 


None 


Checked-Out 


Create 


All 


Checked Out 


Checked-In 


Check-In 


Group A 


Checked-In 


Checked-Out 


Check-Out 


All 
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Checked-In 


Expired 


Delete 


Group B 


Expired 


Checked-In 


Restore 


Group B 


Tab1 


el- Sample State Transitions 



From the set of all possible valid transitions, the presently valid transitions can be 
determined based on the current state. Thus for example, if DOC a is currently in a 
"Checked-In" state, the possible valid state transitions and thus operations are "Check-Out" 

5 and "Delete." Hence, this set of states could be returned to the user. However, in accordance 
with an aspect of the invention, the set of valid operations could be further filtered based on 
the user's credentials. For example, it may be the case that all users are not permitted to 
perform a "Delete" operation. Accordingly, the users credentials are examined and 
compared to the Credential required to perform the operation. So in the present example in 

10 order to perform the operation of "Delete," the user must have a credential available to users 
in Group B; whereas all users may merely "Check-Out" DOC A (309). 

In accordance with another aspect of the invention, by storing the possible 
state transitions centrally, the operation (transition) name may be easily converted to a 
localized name. By merely examining the users language parameter, the operation name may 

15 be converted by the server before returning the operation name to the user. This ensures that 

the server always returned the allowed operations in the language of the client user. 

After determining the set of valid operations, the server request infrastructure 23 

returns the set of filtered operations to client components 21 (3 1 1). Continuing with the 

document management example, where DOCa is in a "Checked-In" state, in an exemplary 

14 
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embodiment the set of filtered operations returned to client components 21 may take the form 
of: 

<Ops Allowed> 
<Value>Check-Out</Value> 
5 <Value>Delete</Value> 
</Ops Allowed> 

When client components 21 receives the set of operations allowed, the operations are 
presented to the user (313). This is the essence of the invention - at this point, the client 
requires no local logic for determining what operations are allowed. Figure 5 shows how a 

10 "File" drop-down box would display the available operations. If, for example, the user 
selected "Check-Out," the client components 21 would then transmit the selection back to 
server request infrastructure 23 (315). In an exemplary embodiment, the request would take 
the form of: INVOKE DOC A <operation>Check-Out</operation>. Server request 
infrastructure 23 would then update the current state of DOCa. 

15 Along with the list of operations, the server can optionally send back a template of the 

HTTP invoke command to the client. The client processing then would simply reduce to: 

• Receiving the choice of operation from the client; 

• Displaying the necessary user interface to fill-in the template received from the server; 
20 • Sending the filled out request to the server. 

In this way, the client can be made agnostic of the functionality of the server. 

Figure 6 illustrates an exemplary computing environment in which the 
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program code that embodies the methods or system of the present invention may be 
executed. Those skilled in the art will appreciate that the invention may be practiced with 
other computer system configurations, including hand-held devices, multiprocessor systems, 
microprocessor-based or programmable consumer electronics, network PCs, minicomputers, 

5 mainframe computers, and the like. The invention may also be practiced in distributed 
computing environments where tasks are performed by remote processing devices that are 
linked through a communications network. In a distributed computing environment, program 
code and program modules comprising program code may be located in both local and 
remote memory storage devices. 

10 With reference to Figure 6, an exemplary system for implementing the 

invention includes a general purpose computing device in the form of a conventional 
computer 1 120, including a processing unit 1 121, a system memory 1 122, and a system bus 
1123 that couples various system components including the system memory to the processing 
unit 1121. The system bus 1 1 23 may be any of several types of bus structures including a 

15 memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of 
bus architectures. The system memory includes read only memory (ROM) 1124 and random 
access memory (RAM) 1 125. A basic input/output system 1 126 (BIOS), containing the basic 
routines that helps to transfer information between elements within the computer 1 120, such 
as during start-up, is stored in ROM 1124. The computer 1 120 further includes a hard disk 

20 drive 1 127 for reading from and writing to a hard disk, not shown, a magnetic disk drive 

1 128 for reading from or writing to a removable magnetic disk 1 129, and an optical disk 
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drive 1 130 for reading from or writing to a removable optical disk 1131 such as a CD ROM 
or other optical media. The hard disk drive 1 127, magnetic disk drive 1 128, and optical disk 
drive 1 130 are connected to the system bus 1 123 by a hard disk drive interface 1 132, a 
magnetic disk drive interface 1133, and an optical drive interface 1134, respectively. The 

5 drives and their associated computer-readable media provide nonvolatile storage of computer 
readable instructions, data structures, program modules and other data for the computer 1 120. 
Although the exemplary environment described herein employs a hard disk, a removable 
magnetic disk 1 129 and a removable optical disk 1131, it should be appreciated by those 
skilled in the art that other types of computer readable media which can store data that is 

10 accessible by a computer, such as magnetic cassettes, flash memory cards, digital video 
disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROM), 
and the like, may also be used in the exemplary operating environment. 

A number of program modules may be stored on the hard disk, magnetic disk 
1129, optical disk 1131, ROM 1124 or RAM 1125, including an operating system 1135, one 

15 or more application programs 1136, other program modules 1137, and program data 1 138. A 
user may enter commands and information into the computer 1 120 through input devices 
such as a keyboard 1 140 and pointing device 1 142. Other input devices (not shown) may 
include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and 
other input devices are often connected to the processing unit 1 121 through a serial port 

20 interface 1 146 that is coupled to the system bus, but may be connected by other interfaces, 

such as a parallel port, game port or a universal serial bus (USB). A monitor 1 147 or other 
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type of display device is also connected to the system bus 1 123 via an interface, such as a 
video adapter 1 148. In addition to the monitor, computers typically include other peripheral 
output devices (not shown), such as speakers and printers. 

The computer 1 120 may operate in a networked environment using logical 

5 connections to one or more remote computers, such as a remote computer 1 149. The remote 
computer 1 149 may be mother computer, a server, a router, a network PC, a peer device or 
other common network node, and typically includes many or all of the elements described 
above relative to the computer 1 120, although only a memory storage device 1 150 has been 
illustrated in Figure 6. The logical connections depicted in Figure 6 include a local area 

10 network (LAN) 1151 and a wide area network (WAN) 1 1 52. Such networking environments 
are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. 

When used in a LAN networking environment, the computer 1 120 is 
connected to the local network 1151 through a network interface or adapter 1153. When 
used in a WAN networking environment, the computer 1 120 typically includes a modem 

15 1 1 54 or other means for establishing communications over the wide area network 1 1 52, such 
as the Internet. The modem 1 154, which may be internal or external, is connected to the 
system bus 1123 via the serial port interface 1 146. In a networked environment, program 
modules depicted relative to the computer 1 120, or portions thereof, may be stored in the 
remote memory storage device. It will be appreciated that the network connections shown 

20 are exemplary and other means of establishing a communications link between the computers 
may be used. 
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While the invention is susceptible to various modifications and alternative 
constructions, certain illustrated embodiments have been shown in the drawings and 
accompanying detailed description. It should be understood, however, that there is no 
intention to limit the invention to the specific constructions disclosed herein. For example, 

5 while the primary example used throughout was described in connection with a document 
management system, the present invention is by no means limited to such a system, but could 
be useful in any system wherein textual, graphic, or other information is managed. Indeed, 
any system which can be modeled as a finite state machine that requires interaction from 
remote clients to transition from one state to another in that state machine, would benefit 

10 from the invention. As such, the invention is intended to cover all modifications, alternative 
constructions, and equivalents falling within the scope and spirit of the invention. 
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CLAIMS 

WHAT IS CLAIMED IS : 

1. A method for controlling operations on an object, comprising the acts of: 

5 providing a server maintaining at least one object, wherein the object is 

capable of existing in one state selected from a set of states; 

maintaining the set of states associated with said object and state transitions 
for indicating valid transitions among states in the set of states and maintaining an 
indication of a current state of said object wherein said current state is a state selected 
10 from said set of states; 

receiving a request for said object from a second computer; and 
providing said object, an indication of said current state, and an indication of 
selected state transitions based on said current state to said second computer whereby 
the second computer may only perform the state transitions based on said selected 
1 5 state transitions. 

2. The method of claim 1 wherein the object comprises a document. 

3. The method of claim 1 wherein the selected state transitions are filtered based on 
20 the permissions granted to the requestor. 



20 



MS Ref. No. 155639.1 
WWKMN Ref. No. MSFT-0204 



4 The method of claim 1 wherein the selected states transitions are transmitted as 
operations that may be performed upon the object. 

5. The method of claim 4 wherein the server determines the names of the operations 
5 in accordance with a local language of the requestor. 

6. The method as recited in claim 1 further comprising the act of receiving a request 
to transition the object to another state wherein the another state is one of the selected state 
transitions. 

10 

7. The method as recited in claim 6 further comprising the act of changing the state 
of the object to the another state. 

8. The method as recited in claim 1 wherein the selected states are maintained in a 
15 table of states and associated valid state transitions that are associated with the object. 

9. A computer-readable medium bearing computer executable instructions capable of 
carrying out the acts recited in claim 1 . 
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10. An object management system, comprising: 

a data structure for at least one object in a set of objects in said object management 
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system, comprising for said at least one object a set of states in which said object may be 
maintained, a set of transitions between said states, and a current state; 

computer-readable server instructions that receive requests from a client for said 
object and retrieve from said data structure at least a subset of transitions between states, 
5 where said subset of transitions is based upon transitions out of the current state; and 

computer-readable server instructions that return to said client an indication of at least 
the subset of transitions between states. 

1 1 . The object management system as recited in claim 10 further comprising 
10 computer-readable server instructions capable of changing the data structure to change the 
current state of the at least one object to a selected state of the states in the set of states where 
the selected state is based on a transition between states contained in the subset of transitions 
returned to the client. 

15 12. The object management system as recited in claim 10 wherein the objects 

comprises documents. 

13. The object management system as recited in claim 10 wherein the recited 
computer-readable instructions reside on a server accessible by way of a network. 

20 

14. The object management system as recited in claim 13 wherein the network 
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comprises an Internet. 

15. The object management system as recited in claim 10 further comprising a set of 
computer-readable instructions residing on a client, said computer-readable instructions 
5 requesting from said computer-readable server instructions a subset of state transitions for the 
at least one object, receiving in return the subset of state transitions, and presenting a user 
with operations capable of being performed on said object where the operations are based on 
the subset of state transitions. 

10 16. The system of claim 10 wherein the indication of the subset states transitions are 

transmitted as operations that may be performed upon the object. 

17. The system of claim 16 wherein the indication of the operations are presented in 
accordance with a local language of the requestor, 

15 

1 8. The system as recited in claim 10 wherein the set of states are maintained in a 
table of states and associated valid state transitions that are associated with the object. 

19. A method of interacting with an object management system, comprising: 

20 providing a indication of a plurality objects within the object management system; 

inputting a request to operate upon a selected one of the plurality of objects within the 
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object management system; 

transmitting the request to a server that maintains a data structure for the selected 
object comprising a set of states in which the object may exist, a set of transitions between 
said states, and a current object state, whereby the server provides an indication of a subset of 
5 transitions between states, where said subset of transitions is based upon transitions out of the 
current object state; and 

providing an indication of operations that may be performed upon said object where 
said operations are based upon the subset of transitions provided by the server. 

10 20. The method of claim 19 wherein the object is a document. 

21. The method of claim 20 wherein the operations comprise document check-out 
operations. 

22. The method of claim 19 wherein the act of transmitting occurs of a computer 
15 network. 

23. The method of claim 22 wherein the network comprises an Internet. 
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ABSTRACT OF THE INVENTION 

A system and method employ a client-server architecture that abstracts from the client 
the states of objects and transitions between the states. As a result, the server maintains 

5 objects, along with associated states, and state transitions that are provided to clients on 
demand. The client is only provided with a set of valid transitions between states that are 
based on the current state of the object and valid transitions out of that state. The states may 
be additionally filtered based on the permissions granted to the client. In this way, the client 
is relieved of prior knowledge of valid object states and state transitions. Hence, in a 

10 document management system, for example, new states and transitions for objects may be 
added at the server and propagated through to the clients. 
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